revealer: Port to no-window widget
authorBenjamin Otte <otte@redhat.com>
Thu, 3 Nov 2016 01:37:52 +0000 (02:37 +0100)
committerBenjamin Otte <otte@redhat.com>
Thu, 3 Nov 2016 02:00:15 +0000 (03:00 +0100)
gtk/gtkrevealer.c

index 857cd7a78ec1d7555681a57b2c2d5546329c21af..ae4f14164b8fddc02f9c26c53dd9941ba8314392 100644 (file)
@@ -134,7 +134,7 @@ gtk_revealer_init (GtkRevealer *revealer)
   priv->current_pos = 0.0;
   priv->target_pos = 0.0;
 
-  gtk_widget_set_has_window ((GtkWidget*) revealer, TRUE);
+  gtk_widget_set_has_window ((GtkWidget*) revealer, FALSE);
   gtk_widget_set_redraw_on_allocate ((GtkWidget*) revealer, FALSE);
 }
 
@@ -341,7 +341,7 @@ gtk_revealer_real_realize (GtkWidget *widget)
   GtkRevealerTransitionType transition;
   GtkBorder padding;
 
-  gtk_widget_set_realized (widget, TRUE);
+  GTK_WIDGET_CLASS (gtk_revealer_parent_class)->realize (widget);
 
   gtk_widget_get_allocation (widget, &allocation);
 
@@ -349,7 +349,6 @@ gtk_revealer_real_realize (GtkWidget *widget)
     gdk_window_new_child (gtk_widget_get_parent_window (widget),
                           gtk_widget_get_events (widget),
                           &allocation);
-  gtk_widget_set_window (widget, priv->view_window);
   gtk_widget_register_window (widget, priv->view_window);
 
   gtk_revealer_get_child_allocation (revealer, &allocation, &child_allocation);
@@ -395,6 +394,10 @@ gtk_revealer_real_unrealize (GtkWidget *widget)
 
   gtk_widget_unregister_window (widget, priv->bin_window);
   gdk_window_destroy (priv->bin_window);
+  priv->bin_window = NULL;
+
+  gtk_widget_unregister_window (widget, priv->view_window);
+  gdk_window_destroy (priv->view_window);
   priv->view_window = NULL;
 
   GTK_WIDGET_CLASS (gtk_revealer_parent_class)->unrealize (widget);
@@ -640,6 +643,9 @@ static void
 gtk_revealer_real_unmap (GtkWidget *widget)
 {
   GtkRevealer *revealer = GTK_REVEALER (widget);
+  GtkRevealerPrivate *priv = gtk_revealer_get_instance_private (revealer);
+
+  gdk_window_hide (priv->view_window);
 
   GTK_WIDGET_CLASS (gtk_revealer_parent_class)->unmap (widget);